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ASYNCHRONOUS PACKET PROCESSING 
USING MEDIA STREAM FUNCTIONS 

BACKGROUND 

1. FIELD OF THE INVENTION 

The present invention pertains to the processing of streams of information in a 
telecommunications node or network. 

2. RELATED ART AND OTHER CONSIDERATIONS 

Time Division Multiplexing (TDM) is a technique for transmitting streams of 
information (e.g., speech information) in time slots repeated at regular intervals. As 
one example, a 64 kbps uncompressed speech stream has a slot in each of consecutive 
125 microsecond TDM time frames. In accordance with a European standard know as 
GSM (Global System for Mobile communications), the TDM time frames are 20 
milliseconds in duration, while in another standard known as G.729 the TDM time 
frames are 10 milliseconds in duration. 

At various nodes of a telecommunication network the time slots of the speech 
streams may undergo processing, with speech processing resources being allocated for 
a specific speech (voice) channel when the time slot is received. It is generally 
preferably to perform the speech processing using software rather than hardware, 
particularly in view of the continuous development of new speech algorithms. Yet 
deterministic resource allocation in the node may lead to insufficient usage of the 
speech processing resources. 

Allocation speech processing resources at a node for every time slot can 
undesirably consume processor resources, and exact a disproportionate amount of 
processor overhead relative to the small amount of data that is included in a speech time 



2 

slot. This is especially true if the networks which interface with the node are packet 
based. 

Illustrating the foregoing, Fig. 1 describes a prior art TDM technique wherein 
seven different 64 kbps speech streams have their respective one octet time slots 
repeated every 125 microseconds. In particular, Fig. 1 shows a TDM frame 18 which 
includes time slots 20 1 - 20 7 for the respective seven speech streams. Moreover, in Fig. 
1 the first time slot 20 j (e.g., for the first speech stream) is expanded in representative 
manner to show what happens during the time duration of the time slot 20 1 with respect 
to the speech information carried in time slot 20 h including processor operations 
performed with respect to the speech information carried in time slot 20 x during the 
time slot20i. 

In Fig. 1, time 21! (which is a first portion of the time slot 200 is required for the 
processor to resume execution of its processing function, such processing function 
having been suspended after processing of the time slot in the previous frame. Once 
execution of the processing function is resumed, during time 22j the processing 
function actually processes the speech data carried in time slot 20 u sending the 
processed speech data out in an outgoing time slot 30j of an outgoing frame 28. Time 
23 1 is required to suspend operation of the processing function. Time 24i reflects the 
fact that the resume time 2l u processing time 22 u and suspend time 23 1 typically do 
not entirely fill the time slot 20j. Moreover, it should be understood that the resume 
time 21 1, processing time 22 u and suspend time 23 1 may vary from processing function 
to processing function, and further that the durations of these times can depend upon 
other factors such as the nature of the incoming speech data (e.g., active or silence 
speech). 

Fig. 1 also illustrates how processor resources might be wasted during call setup 
and call tear down. For example, if time slot 20 5 is allocated to a call which is 
undergoing call setup or call tear down, time slot 20 5 is reserved but the processing 
resources allocated thereto are unused until the called party picks up the telephone or 
the calling party gets tired of waiting. 

Thus, times 21 { and 23 1 of time slot 20 x are times of processing overhead. Since 
time slot 20i is representative potentially of all time slots in frame 18, such processing 



3 

overhead can occur for each time slot carrying actual voice data. Times 24 x and time 
slot 20 5 depict examples of wasted processor resources as may occur when there is no 
actual voice data during call setup or call tear down. 

Fig. 2 shows an example prior art node 40 which performs processing on seven 
speech streams such as those illustrated in Fig. 1. The seven speech streams are 
received in TDM frames at node 40 on line 41 . After processing at node 40, the speech 
streams are output on line 42. The node 40 includes a TDM circuit switch 44 which 
interconnects processors 46i through 46 n . Each processor executes one or more speech 
processing functions, referenced as media stream processing functions or media stream 
applications (MSA). For example, processor 46 1 hosts media stream processing 
functions 47 u through 47 7?1 (MSA U through MSA 7j i), which process data with respect 
to the respective seven speech streams 48 x through 48 7 . Similarly, processor 46 3 hosts 
media stream processing functions 47i ;3 through 47 7?3 (MSA U through MSA 7)3 ). In the 
notation of Fig. 2, the first subscript for a media stream processing function 47 refers to 
the particular media stream which it processes, while the second subscript for a media 
stream processing function 47 distinguishes the function from other functions 
performed with respect to the same media stream. 

In node 40 of Fig. 2, the TDMA circuit switch 44 transfers time slots between 
the media stream processing functions 47, and thereby serves to allocate the number of 
time slots to the processors 46 which host the media stream processing functions 47. 
The number of time slots allocated to any processor 46 is based on that processor's 
capacity with respect to the worst case processing requirements of the particular media 
stream processing function 47 which it executes. For example, if the expected worst 
case per slot processor utilization time for a particular processor with respect to its 
media stream processing function 47 is 15.7 microseconds (|us) , then only seven time 
slots can be allocated. Even then, the allocation of seven time slots results in a waste of 
15.1 microseconds processing time [125 |us - (7 x 15.7 jis)]. Since the allocation is 
typically based on worst case MSA processing time, performance of the media stream 
processing functions in better case scenarios results in even more wasted processor 
capacity. 

Thus, typically allocation of time slots to media streaming handling processors 
within a multi-processor node is unfortunately based on worst case scenarios. Worst 
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case premised time slot allocation results in inefficient use of processor resources, but is 
necessary in a system which synchronously handles time slots. Moreover, as evidenced 
from the situation depicted in Fig. 1, even within times slots there is time lost to 
processor overhead and potentially idle processor resources. 

What is needed, therefore, and an object of the present invention, is a technique 
for which facilitates prudently allocating of time slots in a node which processes media 
streams. 

BRIEF SUMMARY OF THE INVENTION 

A media stream system (140) processes plural media streams (148), e.g., speech 
streams or speech channels. The system comprises plural processors (146), each of 
which execute one of plural types of media stream processing functions (147). A 
switch function (144) routes packets of the plural media streams to a sequence of the 
plural processors whereby the plural types of media stream processing functions are 
sequentially performed relative to the packets. The types of media stream processing 
functions can include functions such as the following: speech coding; speech decoding; 
echo cancellation; tone sender; tone receiver; DTMF sender; DTMF receiver; 
conference call device (CCD); announcement machine; FAX modem; voice recogition; 
and U-lag/A-lag conversion; an interfacing functionality to an external network (such 
as TDM, ATM, IP and Frame Relay networks); video codec (which, e.g., processes 
video and/or video clips), text processing (which converts text to voice or text to video), 
a modem for either circuit switched or packet switched data. 

A packet size for the packets is chosen to minimize overhead load on at least one 
of the plural processors without causing undue delay for a packet awaiting processing 
by the at least one of the plural processors. In one example non-limiting illustrated 
implementation, the packet size for a packet of media information is chosen to be 160 
octets. In the example non-limiting illustrated implementation, consecutive packets of 
a same media stream are separated by a packet repetition interval which is 20 
milliseconds. 

The switch function asynchronously routes the packets of the plural media 
streams to a sequence of the plural processors. In each processor there is a queue for 
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temporarily storing a packet received while the processor performs its media stream 
processing function relative to another packet. 

In differing embodiments, the switch function comprises one of a packet switch 
and a cell switch, or one of a packet-based and a cell-based network. 

Because of the packet size afforded by the present invention, the number of 
events, both in the user plane and the control plane, are lower than if traditional speech 
time slots were to be handled one by one as in the prior art. This results in lower 
processing overhead, and therefore lower processor load. Advantageously, the software 
need not switch or change context as often. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The foregoing and other objects, features, and advantages of the invention will 
be apparent from the following more particular description of preferred embodiments as 
illustrated in the accompanying drawings in which reference characters refer to the 
same parts throughout the various views. The drawings are not necessarily to scale, 
emphasis instead being placed upon illustrating the principles of the invention. 

Fig. 1 is a diagrammatic view showing a prior art TDM transmission technique. 

Fig. 2 is a diagrammatic view of a prior art node which processes TDM speech 
time slots. 

Fig. 3 is a diagrammatic view of a generic system which processes media 
streams in accordance with an example embodiment of the present invention. 

Fig. 3A is a diagrammatic view of a system which processes media streams in 
accordance with an example embodiment of the present invention, and which uses a 
packet switch or cell switch to perform a switching function. 

Fig. 3B is a diagrammatic view of a system which processes media streams in 
accordance with an example embodiment of the present invention, and wherein a 
switching function is performed by a packet or cell network. 
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Fig. 4 is a diagrammatic view of an example configuration of a processor of the 
node of Fig. 3. 

Fig. 5 is a diagrammatic view showing a media stream transmission technique 
according to an embodiment of the present invention. 

Fig. 6 is a diagrammatic view showing an illustrative sequence of media stream 
applications which can be performed for a speech stream. 

DETAILED DESCRIPTION OF THE DRAWINGS 

In the following description, for purposes of explanation and not limitation, 
specific details are set forth such as particular architectures, interfaces, techniques, etc. 
in order to provide a thorough understanding of the present invention. However, it will 
be apparent to those skilled in the art that the present invention may be practiced in 
other embodiments that depart from these specific details. In other instances, detailed 
descriptions of well known devices, circuits, and methods are omitted so as not to 
obscure the description of the present invention with unnecessary detail. 

Fig. 3 shows a media stream system 140 which processes plural media streams. 
The media stream system 140 can be situated at or comprise a node of a network, such 
as a telecommunications network, for example. Alternatively, media stream system 
140 can itself comprise a network . In one particular direction of stream flow, the 
media stream system 140 receives the plural media streams on line 141, processes one 
or more of the plural media streams, and outputs the media streams on line 142. 

The heart of media stream system 140 is a switch function, generically 
illustrated as switch function 144 in Fig. 3. Fig. 3A shows an embodiment in which the 
switch function is a switch 144A which can be a packet switch, cell switch, or any 
node-included switch suitable for routing packets of media information as hereinafter 
described. Fig. 3B, on the other hand, shows an embodiment in which the switch 
function is a packet-based or cell-based network 144B, such as (for example) an 
Internet Protocol (IP) network, an ATM network, or Frame Relay network. For sake of 
simplicity and inclusion of all embodiments, the switch function is hereinafter referred 
to as "switch 144 M . The switch 144 has differing ports (in the case of Fig. 3A) or nodes 
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(e.g., in the case of Fig. 3B) thereof connected to differing processors 146. For sake of 
illustration, five such processors 146i - 146 5 are shown in Fig. 3. 

The media stream system 140 of the present invention processes media stream 
packets, the size of the packets being particularly chosen according to packet size 
criteria of the invention. Choice of packet size in accordance with the present invention 
results in more economical use of the processors 146, which has various attendant 
advantages. One such advantage is that media stream system 140 can handle a greater 
number of media streams, if desired. For example, whereas the prior art node 40 of Fig. 
2 handled seven streams, the illustrative example media stream system 140 of Fig. 3 
handles nine media streams 148! through 148 9 . 

Each processor 146 executes one or more media stream processing functions or 
media stream applications (MSAs) 147, there being several different types of media 
stream processing functions. For example, processor 146i hosts media stream 
processing functions 147 u through 147 9> i (MSA M through MSA 9 ,0, which process 
data with respect to the respective nine media streams 148i through 148 9 . Similarly, 
processor 146 3 hosts media stream processing functions 147i ;3 through 147 9;3 (MSAi )3 
through MSA 9 , 3 ). As in Fig. 2, in the notation of Fig. 3 the first subscript for a media 
stream processing function 147 refers to the particular media stream which it processes, 
while the second subscript for a media stream processing function 147 distinguishes the 
function from other functions performed with respect to the same media stream. 

A generic one of the processors 146 is shown in Fig. 4 as comprising a 
processing unit 150. The processing unit 150 executes one or more of the media stream 
processing functions 147. In one embodiment, the processors 146 can be digital signal 
processors (DSPs). Other types of units for executing the media stream processing 
functions 147 are within the scope of the present invention. 

Switch 144 asynchronously routes each of the packets of the plural media 
streams received at system 140 to a sequence of the plural processors 146, so that the 
types of media stream processing functions 147 hosted at that sequence of processors 
146 are sequentially performed relative to the packets. Accordingly, Fig. 4 shows 
processor 146 as being connected to an output port/node of switch 144 by line 151 over 
which a packet-to-be processed by processing unit 1 50 is received. Further, after a 
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packet has been processed by processing unit 150, it is output on line 152 for 
transmission back to switch 144. Switch 144 is thus in a position to route the packet to 
yet another processor 146 for further processing, or out of system 140 should 
processing be completed. 

As mentioned above, switch 144 asynchronously routes each of the packets of 
the plural media streams to a sequence of the plural processors 146 comprising system 
140. By asynchronous is meant that there is no established time relationship between 
the reception and/or discharge of packets at one processor 146 with the reception and/or 
discharge of packets at another processor, or no timed relation in the routing of packets 
by switch 144 to plural processors 146. Rather, when a processor 146 has completed its 
processing, it is sent to switch 144, and switch 144 then routes the packet to another 
processor (or out of system 140) as soon as possible. Thus, the time between incoming 
packets is not the same as the time between outgoing packets for different streams, 
since (among other factors) different streams may require different processing time. 

Several packets belonging to different media streams can arrive almost 
simultaneously at a processor 146 while that processor is already involved in exeucting 
a media stream function 147 in its processing unit 150. In view of the asynchronous 
nature of the routing of packets by switch 144, the processors 146 have a buffer register 
(e.g., preferably a first-in, first-out (FIFO) register) 156 functionally positioned between 
the input line 151 from switch 144 and their processing unit 150. The FIFOs 156 serve 
to hold any packets received at a processor 146 which, in view of the asynchronous 
nature of system 1 40, are awaiting completion of processing of a preceding packet by 
the processing unit 150 of the processor 146 prior to being processed themselves. In 
other words, the FIFOs 156 compensate for random arrival of packets within the given 
packet repetition rate due to introduced jitter. The packet(s) awaiting in FIFO 156 thus 
may experience some delay in gaining access to processing unit 150 so that the 
corresponding media stream application 147 can be executed with respect thereto. 
Accordingly, there can be some variation in the packet repetition time for the outgoing 
packet. 

As alluded to above, in accordance with one aspect of the present invention, the 
packet size for the media stream packets is chosen to minimize overhead load on a 
processor 146, without causing undue delay for a packet awaiting processing by that 
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processor. Fig. 5 illustrates the nature and advantages of the packet size of this aspect 
of the present invention. 

As shown in Fig. 5, in one example, non-limiting embodiment of the present 
invention the packet size for a packet of media stream information is chosen to be 160 
octets. In view of its size, each packet of media stream information is also referred to 
as a "batch". Fig. 5 further shows nine such packets 160! through 160 9 being included 
in a packet repetition interval 170. Preferably the packet repetition interval is 20 
milliseconds. Thus, consecutive packets of a same media stream (e.g., media stream 
1480 are separated by the packet repetition interval 170 (e.g., the packet 160i show in 
Fig. 5 is followed 20 milliseconds by another packet of the same media stream). The 
packet size and packet repetition interval 170 of the Fig. 5 embodiment is merely one 
example, it being recognized that other packet sizes and other lengths for the packet 
repetition interval 170 can be utilized in other embodiments. 

Certain ones of the packets 160 in Fig. 5, particularly packets 160i through 160 3 
and packet 160 9 , are illustrated also as "batch 1", "batch 2", "batch 3", and "batch" 9", 
respectively. Moreover, Fig. 5 shows an enlargement of packet 160i for sake of 
illustrating the corresponding processing time required by a representative one of the 
processors 146 for performing its media stream application 147 relative to packet 160i. 
The required processing time for packet 160! first includes a resume process time 161 1 
which is required to resume execution of the media stream application 147 performed 
by processor 146. The required processing time for packet 160i also includes an actual 
processing time 162i, during which time the processor 146 processes the media stream 
application relative to packet 160i. After actual processing of the packet 160! by the 
media stream application 147 is completed, the required processing time for packet 
160i further includes a suspend time 163i to afford the processor 146 an opportunity to 
suspend action of the media stream application 147 in anticipation of handling yet 
another packet. 

Each processor 146 has a certain overhead load associated with the execution of 
the media stream applications 147 which it hosts. The overhead load includes 
operations of resuming and suspending execution of a media stream processing 
function for packets of different media streams. With reference to Fig. 5, for example, 
the overhead load for a processor includes its activities of resuming execution of its 
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media stream application (which has an overhead resume time 161 1) and of suspending 
execution of its media stream application (which has an overhead resume time 1630 
after the packet 160i has been processed. 

By choosing 160 octets as the size for each media stream packet, less time is 
consumed by the processor 146 in resuming and suspending execution of the media 
stream application 147 than is the case, for example, in Fig. 1. In other words, the time 
marked in Fig. 1 as "potential gain" can be utilized for processing rather than for 
resuming and suspending operations. Moreover, the overhead load for a processor is 
more effectively spread over a larger time base of information per media stream, 
thereby economizing processor execution and therefore allowing greater use of 
processing resources. For example, in the embodiment of Fig. 4 nine media streams 
148i - 148 9 are handled by system 140, as opposed to a lesser number when packet 
sizes are smaller than the 160 octets of the present invention. 

Thus, one aspect of the invention is grouping or formatting of the media stream 
data so that each processor, upon executing its MSA, does so for 160 consecutive times 
slots, rather than for just one time slot. Therefore, there are not resume and suspend 
periods for the processor between handling each time slot. Advantageously, in view of 
the greater efficiency, the processor can now handled more traffic, e.g., more media 
streams and/or more MS As . 

After a packet is processed by a media stream application 147 executed by one 
of the processors 146, that packet (of 160 octets) is output by the processor (e.g., on line 
142) to switch 144. In Fig. 5, output packet 180! corresponds to the packet 160! whose 
processing was just described. 

Fig. 3 illustrates how switch 144 routes packets of the various media streams 148 
to a sequence of different processors 146. For example, packets of media stream 148 x 
are routed first to media stream application 147 u hosted at processor 146i. Upon 
completion of the processing by media stream application 147 u , the packet of the first 
media stream is returned to switch 144, so that switch 144 can route the packet to media 
stream application 147 u which is hosted at processor 146 3 . As further shown by Fig. 
4, the packets of the first media stream are eventually routed to processor 146 2 where 
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execution of media stream application 147i ;2 is performed, and then via switch 144 to 
processor 146 n where media stream application 147i, n is performed. 

The sequence of processors 146 to which packets of differing media streams are 
routed can differ. In contrast to the sequence for packets of the first media stream as 
described in the previous paragraph, in Fig. 4 it is seen that the packets of the ninth 
media stream 148 9 are routed in a different sequence. In this regard, the packets of the 
ninth media stream 148 9 are routed to processor 146 4 for performance of media stream 
application 147 9;4 prior to being routed to processor 146 n , instead of being routed to 
processor 146 2 prior to being routed to processor 146 n . Thus, for differing media 
streams there can be a differing sequence of processor routings, which can mean a 
difference in the types of media stream applications that are performed, and a difference 
in the order of performance of the media stream applications. 

As mentioned above, plural types of media stream processing functions can be, 
and typically are, performed relative to one or more media streams at system 140. The 
plural types of media stream processing functions include one or more of the following: 
speech coding; speech decoding; echo cancellation; tone sender; tone receiver; DTMF 
sender; DTMF receiver; conference call device (CCD); announcement machine; FAX 
modem; voice recogition; U-lag/A-lag conversion; an interfacing functionality to an 
external network (such as TDM, ATM, IP and Frame Relay networks); video codec 
(which, e.g., processes video and/or video clips), text processing (which converts text to 
voice or text to video), a modem for either circuit switched or packet switched data. 

In one example, non-limiting mode of the invention, the media streams are 
speech streams (e.g., channels of speech data). Fig. 6 provides an illustrative depiction 
of a sequence of media stream applications which can be performed for a speech stream 
x in a PLMN in a downlink direction (e.g., the call originating in a PSTN). In the 
example mode of Fig. 6, the switch 144 first routes the packet for speech stream x to a 
first processor whereat media stream application 147 x j is performed; then to a second 
processor whereat media stream application 147 Xj2 is performed; then to a third 
processor whereat media stream application 147 x 3 is performed. In the illustrated 
scenario of Fig. 6, media stream application 147 x> i is an echo canceller; media stream 
application 147 x , 2 is a U-lag/A-lag conversion process; media stream application 147 Xj3 
is a coder/decoder (CODEC). 
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As mentioned above, in the present invention packets or batches of media stream 
information are processed and routed asynchronously, e.g., as fast as possible. 
However, system 140 may interconnect to another system which, by contrast, is 
synchronous. Such synchronous system could be, for example, an exchange in PSTN 
(such as, for example, an Ericsson AXE 10 exchange). In order to interface with a 
synchronous system, an interface device such as an exchange terminal (e.g., an El 
board) is provided at an edge of system 140 to enable the packets of media stream 
information handled by system 140 to regain synchronization with the outside world. 
There are various ways in which the resynchronization can be accomplished. One 
example, non-limiting way in which such regaining of synchronization can be 
accomplished is to buffer the outgoing stream of packets on the interface board and 
clock out the packets in typical TDM manner (e.g., the stream into the buffer is 
asynchronous and the stream clocked out from the buffer is synchronous). Thus, 
synchronization to circuit based TDM or circuit emulation networks is performed as 
close as possible to the edge of system 140, e.g., as the output of the last media stream 
function 147. Such time alignment is necessary largely only when interconnecting with 
circuit based TDM or circuit emulation networks. Media streams coming from a circuit 
based TDM or circuit emulation network are converted to a packet (e.g., batch) in the 
asynchronous domain of the present invention at, e.g., the first media stream function 
147 of the system (e.g., a media stream function which serves as an interface 
functionality to an external network). Such conversions can be to ATM, Internet 
Protocol (IP), and to Frame Relay, for example. 

Thus, in the case of connection to a circuit based TDM or circuit emulation 
network, the media stream functions 147 1?1 through 147 1;9 of Fig. 3 could perform, for 
example, a conversion of packet size suitable for the present invention upon receipt of 
the packets on line 141 from the outside world. The media stream functions 147i ;I1 
through 147 9>n of Fig. 3, on the other hand, could perform re-conversion of packet size 
and synchronization for interfacing to the outside world. 

In case synchronization is not needed, the asynchronous batch processing can be 
made between media stream functions across a network, i.e., the packet switch is 
replaced by a packet or cell based network, e.g., IP, ATM, and frame relay. If Internet 
Protocol is utilized, no adjustment to packet length may be required, as the packet size 
of 160 octets can be utilized at a 20 ms frame repetition time. 
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"Circuit emulation" is a concept employed in ATM networks, where the 
characteristics of the TDM transmission is deployed in the user plane. By circuit 
emulation it is possible to transfer a real-time payload such as voice with TDM 
characteristics in an ATM network. 

The present invention thus advantageously provides better utilization of 
expensive processor resources. For example, the invention provides a lowest delay 
only related to the load applied to the processors. The delay can be further decreased 
by not loading the processors to the maximum, and thus avoiding or decreasing queuing 
delay (e.g., in the FIFOs 156). Thus, the present invention enables attaining a trade off 
between delay and load. 

The present invention also facilitates use of processors in accordance with 
statistical multiplexing. If a processor were to be overbooked (implying a greater 
utilization of processor resources), a lower quality of service (QoS) correlatively 
results. A lower QoS in this context means that randomly a speech packet can be lost. 
This has minor impact on the total voice quality, provided it affects different speech 
streams and the speech packet loss rate is tuned according to speech quality 
requirements. 

Because of the packet size afforded by the present invention, the number of 
events, both in the user plane and the control plane, are lower than if traditional speech 
time slots were to be handled one by one as in the prior art. This results in lower 
processor overhead, and therefore lower processor load. Advantageously, the software 
need not switch or change context as often (e.g., a DSP need not change from 
processing one speech channel to another speech channel as often as in conventional 
practice). 

By implementing time alignment (e.g., synchronization) only at the egress point 
of the system towards circuit switched or circuit emulated networks, no unnecessary 
delay is introduced in the call chain. 

If packet networks are employed, only processing an FIFO queuing delay has to 
be considered in delay computations. 
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While the invention has been described in connection with what is presently 
considered to be the most practical and preferred embodiment, it is to be understood 
that the invention is not to be limited to the disclosed embodiment, but on the contrary, 
is intended to cover various modifications and equivalent arrangements included within 
the spirit and scope of the appended claims. 
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WHAT IS CLAIMED IS: 



1 1 . A media stream system which processes plural media streams, each media 

2 stream comprising packets of media information, the system comprising: 

3 plural processors, each of the plural processors executing at least one of plural 

4 types of media stream processing functions; 

5 a switch function which routes the packets of the plural media streams to a 

6 sequence of the plural processors whereby the plural types of media stream processing 

7 functions are sequentially performed relative to the packets; 

\% 8 wherein a packet size for the packets is chosen to minimize overhead load on at 

;|i 9 least one of the plural processors without causing undue delay for a packet awaiting 

]% 10 processing by the at least one of the plural processors. 

|ij l 2. The system of claim 1 , wherein the packet size for a packet of media 

; ; 2 information is chosen to be 160 octets. 

; 2 i 3. The system of claim 1 , wherein consecutive packets of a same media stream 

Q 2 being separated by a packet repetition interval. 

1 4. The system of claim 3, wherein the packet repetition interval between 

2 consecutive packets of the same media stream is 20 milliseconds. 

l 5. The system of claim 1, wherein the number of plural media streams is nine. 

1 6. The system of claim 1, wherein the plural media streams are one of plural 

2 voice channels and plural video channels. 

1 7. The system of claim 1, wherein the switch asynchronously routes the packets 

2 of the plural media streams to a sequence of the plural processors. 

1 8. The system of claim 7, wherein for at least one of the plural processors there 

2 is a queue for temporarily storing a packet received while the at least one of the plural 

3 processors performs its media stream processing function relative to another packet. 
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1 9. The system of claim 1 5 wherein at least one of the plural processors is a 

2 digital signal processor (DSP). 

l 10. The system of claim 1 , wherein the plural types of media stream processing 



2 functions include at least one of the following: speech coding; speech decoding; echo 

3 cancellation; tone sender; tone receiver; DTMF sender; DTMF receiver; conference call 

4 device (CCD); announcement machine; FAX modem; voice recogition; and U-lag/A- 

5 lag conversion; an interfacing functionality to an external network (such as TDM, 

6 ATM, IP and Frame Relay networks); video codec, text processing, modem for either 

7 circuit switched or packet switched data. 



1 11. The system of claim 1 , wherein the overhead load includes operations of 

2 resuming and suspending execution of a media stream processing function for packets 

3 of different media streams. 

1 12. The system of claim 1, further comprising an interface device which 

2 connects the system to a network wherein the packets of the plural media streams are 

3 transmitted synchronously, wherein the interface device performs a synchronization 

4 with respect to the packets which have been asynchronously routed through the system. 

1 13. The system of claim 1, wherein the switch function comprises one of a 

2 packet switch and a cell switch. 

1 14. The system of claim 1, wherein the switch function comprises one of a 

2 packet-based and a cell-based network. 

1 15. A method of handling plural media streams, each media stream comprising 

2 packets of media information, the method comprising: 

3 executing plural types of media stream processing functions at plural processors; 

4 routing the packets of the plural media streams to a sequence of the plural 

5 processors whereby the plural types of media stream processing functions are 

6 sequentially performed relative to the packets; 

7 choosing a packet size for the packets to minimize overhead load on at least one 

8 of the plural processors without causing undue delay for a packet awaiting processing 

9 by the at least one of the plural processors. 
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1 16. The method of claim 1 5, further comprising choosing the packet size for a 

2 packet of media information to be 160 octets. 

1 17. The method of claim 15, further comprising separating consecutive packets 

2 of a same media stream by a packet repetition interval. 

1 18. The method of claim 15, further comprising choosing the packet repetition 

2 interval between consecutive packets of the same media stream to be 20 milliseconds. 

1 19. The method of claim 15, wherein the number of plural media streams is 

2 nine. 

1 20. The method of claim 15, wherein the plural media streams are one of plural 

2 voice channels and plural video channels. 

1 21 . The method of claim 1 5, further comprising asynchronously routing the 

2 packets of the plural media streams to a sequence of the plural processors. 

1 22. The method of claim 21 , further comprising, for the at least one of the plural 

2 processors, providing a queue for temporarily storing a packet received while the at 

3 least one of the plural processors performs its media stream processing function relative 

4 to another packet. 

1 23. The method of claim 15, further comprising including at least one of the 

2 following as one of the plural types of media stream processing functions: speech 



3 coding; speech decoding; echo cancellation; tone sender; tone receiver; DTMF sender; 

4 DTMF receiver; conference call device (CCD); announcement machine; FAX modem; 

5 voice recogition; and U-lag/A-lag conversion; an interfacing functionality to an external 

6 network (such as TDM, ATM, IP and Frame Relay networks); video codec, text 

7 processing, modem for either circuit switched or packet switched data. 

1 24. The method of claim 1 5, wherein the overhead load includes operations of 

2 resuming and suspending execution of a media stream processing function for packets 

3 of different media streams. 



18 

1 25. The method of claim 15, further comprising providing an interface device to 

2 connect the system to a network wherein the packets of the plural media streams are 

3 transmitted synchronously, and using the interface device to perform a synchronization 

4 with respect to the packets which have been asynchronously routed through the system. 

1 26. The method of claim 15, wherein the step of routing the packets of the plural 

2 media streams involves employing one of a packet switch and a cell switch to route the 

3 packets. 

1 27. The method of claim 1 5, wherein the step of routing the packets of the plural 

2 media streams involves employing one of a packet based network and a cell based 

3 network to route the packets. 

1 28. A media stream system which processes plural media streams, each media 

2 stream comprising packets of media information, the system comprising: 

3 plural processors, each of the plural processors executing at least one of plural 

4 types of media stream processing functions; 

5 a switch function which asynchronously routes the packets of the plural media 

6 streams to a sequence of the plural processors whereby the plural types of media stream 

7 processing functions are sequentially performed relative to the packets; 

8 wherein a packet size for the packets is chosen to be 160 octets. 

1 29. The system of claim 28, wherein consecutive packets of a same media 

2 stream are separated by a packet repetition interval . 

1 30. The system of claim 29, wherein the packet repetition interval between 

2 consecutive packets of the same media stream is 20 milliseconds. 

l 31. The system of claim 28, wherein the number of plural media streams is nine. 

1 32. The system of claim 28, wherein the plural media streams are one of plural 

2 voice channels and plural video channels. 



1 33. The system of claim 28, wherein for at least one of the plural processors 

2 there is a queue for temporarily storing a packet received while the at least one of the 
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3 plural processors performs its media stream processing function relative to another 

4 packet. 

1 34. The system of claim 28, wherein at least one of the plural processors is a 

2 digital signal processor (DSP). 

1 35. The system of claim 28, wherein the plural types of media stream processing 

2 functions include at least one of the following: speech coding; speech decoding; echo 

3 cancellation; tone sender; tone receiver; DTMF sender; DTMF receiver; conference call 

4 device (CCD); announcement machine; FAX modem; voice recogition; and U-lag/A- 

5 lag conversion; an interfacing functionality to an external network (such as TDM, 

6 ATM, IP and Frame Relay networks); video codec, text processing, modem for either 

7 circuit switched or packet switched data. 

1 36. The system of claim 28, further comprising an interface device which 

2 connects the system to a network wherein the packets of the plural media streams are 

3 transmitted synchronously, wherein the interface device performs a synchronization 

4 with respect to the packets which have been asynchronously routed through the system. 

1 37. The system of claim 28, wherein the switch function comprises one of a 

2 packet switch and a cell switch. 

1 38. The system of claim 28, wherein the switch function comprises one of a 

2 packet-based and a cell-based network. 
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ABSTRACT OF THE DISCLOSURE 



A media stream system (140) processes plural media streams (148), e.g., speech 
streams or speech channels. The system comprises plural processors (146), each of 
which execute one or more plural types of media stream processing functions (147). A 
switch function (144) routes packets of the plural media streams to a sequence of the 
plural processors whereby the plural types of media stream processing functions are 
sequentially performed relative to the packets. A packet size for the packets is chosen 
to minimize overhead load on at least one of the plural processors without causing 
undue delay for a packet awaiting processing by the at least one of the plural 
processors. In an example non-limiting implementation, the packet size for a packet of 
media information is chosen to be 160 octets, consecutive packets of a same media 
stream being separated by a packet repetition interval which is 20 milliseconds. 
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